home *** CD-ROM | disk | FTP | other *** search
/ Enter 2004 January / enter-2004-01.iso / files / maxima-5.9.0.exe / {app} / share / maxima / 5.9.0 / src / numerical / slatec / dbesk0.lisp < prev    next >
Encoding:
Text File  |  2003-02-09  |  3.0 KB  |  69 lines

  1. ;;; Compiled by f2cl version 2.0 beta 2002-05-06
  2. ;;; 
  3. ;;; Options: ((:prune-labels nil) (:auto-save t) (:relaxed-array-decls t)
  4. ;;;           (:coerce-assigns :as-needed) (:array-type ':simple-array)
  5. ;;;           (:array-slicing nil) (:declare-common nil)
  6. ;;;           (:float-format double-float))
  7.  
  8. (in-package "SLATEC")
  9.  
  10.  
  11. (let ((ntk0 0)
  12.       (xsml 0.0)
  13.       (xmax 0.0)
  14.       (bk0cs (make-array 16 :element-type 'double-float))
  15.       (first nil))
  16.   (declare (type f2cl-lib:logical first)
  17.            (type (simple-array double-float (16)) bk0cs)
  18.            (type double-float xmax xsml)
  19.            (type f2cl-lib:integer4 ntk0))
  20.   (f2cl-lib:fset (f2cl-lib:fref bk0cs (1) ((1 16))) -0.03532739323390277)
  21.   (f2cl-lib:fset (f2cl-lib:fref bk0cs (2) ((1 16))) 0.3442898999246285)
  22.   (f2cl-lib:fset (f2cl-lib:fref bk0cs (3) ((1 16))) 0.0359799365153615)
  23.   (f2cl-lib:fset (f2cl-lib:fref bk0cs (4) ((1 16))) 0.001264615411446926)
  24.   (f2cl-lib:fset (f2cl-lib:fref bk0cs (5) ((1 16))) 2.286212103119452e-5)
  25.   (f2cl-lib:fset (f2cl-lib:fref bk0cs (6) ((1 16))) 2.5347910790261496e-7)
  26.   (f2cl-lib:fset (f2cl-lib:fref bk0cs (7) ((1 16))) 1.9045163772202092e-9)
  27.   (f2cl-lib:fset (f2cl-lib:fref bk0cs (8) ((1 16))) 1.0349695257633626e-11)
  28.   (f2cl-lib:fset (f2cl-lib:fref bk0cs (9) ((1 16))) 4.2598161427910824e-14)
  29.   (f2cl-lib:fset (f2cl-lib:fref bk0cs (10) ((1 16))) 1.3744654358807512e-16)
  30.   (f2cl-lib:fset (f2cl-lib:fref bk0cs (11) ((1 16))) 3.570896528508374e-19)
  31.   (f2cl-lib:fset (f2cl-lib:fref bk0cs (12) ((1 16))) 7.631643660116437e-22)
  32.   (f2cl-lib:fset (f2cl-lib:fref bk0cs (13) ((1 16))) 1.3654249884407815e-24)
  33.   (f2cl-lib:fset (f2cl-lib:fref bk0cs (14) ((1 16))) 2.0752752669066685e-27)
  34.   (f2cl-lib:fset (f2cl-lib:fref bk0cs (15) ((1 16))) 2.7128142180729853e-30)
  35.   (f2cl-lib:fset (f2cl-lib:fref bk0cs (16) ((1 16))) 3.082593887914667e-33)
  36.   (setq first f2cl-lib:%true%)
  37.   (defun dbesk0 (x)
  38.     (declare (type double-float x))
  39.     (prog ((xmaxt 0.0) (y 0.0) (dbesk0 0.0))
  40.       (declare (type double-float dbesk0 y xmaxt))
  41.       (cond
  42.        (first
  43.         (setf ntk0
  44.                 (initds bk0cs 16
  45.                  (* 0.1f0 (f2cl-lib:freal (f2cl-lib:d1mach 3)))))
  46.         (setf xsml (f2cl-lib:fsqrt (* 4.0 (f2cl-lib:d1mach 3))))
  47.         (setf xmaxt (- (f2cl-lib:flog (f2cl-lib:d1mach 1))))
  48.         (setf xmax
  49.                 (+ xmaxt
  50.                    (/ (* -0.5 xmaxt (f2cl-lib:flog xmaxt)) (+ xmaxt 0.5))))))
  51.       (setf first f2cl-lib:%false%)
  52.       (if (<= x 0.0) (xermsg "SLATEC" "DBESK0" "X IS ZERO OR NEGATIVE" 2 2))
  53.       (if (> x 2.0) (go label20))
  54.       (setf y 0.0)
  55.       (if (> x xsml) (setf y (* x x)))
  56.       (setf dbesk0
  57.               (+ (- (* (- (f2cl-lib:flog (* 0.5 x))) (dbesi0 x)) 0.25)
  58.                  (dcsevl (- (* 0.5 y) 1.0) bk0cs ntk0)))
  59.       (go end_label)
  60.      label20
  61.       (setf dbesk0 0.0)
  62.       (if (> x xmax) (xermsg "SLATEC" "DBESK0" "X SO BIG K0 UNDERFLOWS" 1 1))
  63.       (if (> x xmax) (go end_label))
  64.       (setf dbesk0 (* (exp (- x)) (dbsk0e x)))
  65.       (go end_label)
  66.      end_label
  67.       (return (values dbesk0 nil)))))
  68.  
  69.